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(57) A method for reducing the number of bits 
needed to represent constant values in a data process- 
ing device (100) including the steps of defining a group 
of constant values by selecting them as a function of 
their statistical frequency of use. representing each con- 
stant value of this group in the instructions by means of 
a shorter coded operand field, loading a current instruc- 

100-^ 



tion from a bus (105) in an instruction register (145), 
deriving a corresponding operand field from the coded 
operand field of the current instruction by expansion 
means (150), and selectively connecting the bus (105) 
and an output of the expansion means (150) as input to 
an arithmetic logic unit (1 10). 
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Descriptidn 

The present invention concerns a' method and 
device for reducing the number of bits needed for the 
representation of constant values in a data processing i 
device. 

A data processing device, for example, a micro- 
processor, is constituted by an assembly of digital elec- 
tronic circuits (hardware) able to execute instructions 
stored in a suitable program ( software). A typical 
instnjction comprises a sequence of binary digits (bits) 
and includes a part which indicates the type of opera- 
tion to be executed (operation code), and a part which 
enables the data to be operated on (the operand field) 
to be identified. A data processing device generally uti- 
lises various addressing modes to access this data. In 
particular, in immediate addressing the data is specified 
by referring directly to its value in the instruction (imme- 
diate operand); this method of addressing is particularly 
useful when constant values are to be used. In the 
immediate addressing method, therefore, N bits of the 
operand field are needed to represent 2^ different con- 
stant values. 

Various solutions are known for reducing the 
number of bits necessary for representing constant val- 
ues in instructions intended to contain data to be 
addressed immediately. In so-called short constant sys- 
tems, only Q bits (where Q<N) of lesser significance of 
the constant are represented in the operand field, 
obtaining the bits of greater signrt icance thereof by sign 
extension or zero filling. In particular, in the case of sign 
extension, all the bits of the constant from the position 
Q+1 to the position N-1 are given the same. value as the 
sign bit in position Q, while in the case of zero filling, 
these bits of the constant are given the value 0 ; the val- 
ues which can be represented lie, respectively, in the 
range -2°'"' to a^'"*-! , and the range 0 to 2*^-1 . In single 
bit systems, the constants having a single bit with a 
value of 1 are represented by indicating the position of 
this bit in the constant; in this case, a number of bits P is 
necessary, given by the relationship N = 2 , that is, 
P = logaN . This system is usually used for instructions 
at the single bit level for clear, set, test, and toggle oper- 
ations. 

A disadvantage of the known systems is that only 
certain types of constant can be represented short- 
ened; these systems therefore impose severe limita- 
tions both on the value of the representable constants 
and on their structure. 

In addition, the set of reduced length constants rep- 
resented in the known systems is fixed and is independ- 
ent of the different operative requirements of the data 
processing device. 

The aim of the present invention is to overcome the 
aforesaid disadvantages. To achieve this aim a method 
is provided as described in the first claim. 

The method of the present invention enables differ- 
ent types and structures of constant to be represented 



as a function of the requirements of a wide variety of 
applications. 

In addition, the representation of the constants in 
the method of the present invention depends on the use 

J envisaged for the data processing device; this enables 
the device to be adapted to the applications in which it. 
is used, consequently improving their performance in 
each individual operating condition. 

Further characteristics and advantages of the 

10 method of the present invention will become clearer 
from the following description of a preferred embodi- 
ment, given by way of non-limitative example, with refer- 
ence to the accompanying drawings, in which: 

15 Figure 1 is a data processing device which may be 
used to perform the method of the present inven- 
tion; and 

Figure 2 is an embodiment of the expansion unit of 
Figure 1 . 

20 . _ 

With reference now to the drawings, and with partic- 
ular reference to Figure 1 . a data processing device 
100, specifically a microprocessor (|xP), is shown; how- 
ever, the present invention also lends itself to being put 
25 into practice utilising different data processing devices 
such as, for example, a logic controller. As usual, wide 
an-ows indicate the passage of words, while small 
arrows indicate the passage of single bit commands. 
The data processing device 100 includes an internal 
30 data bus 105 to which is connected an arithmetic-logic 
unit (ALU) 110 which is able to execute calculations and 
checks; a plurality of internal registers 1 15 such as gen- 
eral purpose registers, a program counter, an instruc- 
tions address register, a stack pointer and the like, are 
35 also connected to the bus 105. The data processing 
device also includes a control unit 120 which controls 
the different functions of the various components and 
their access to the internal data bus 105 by means of 
suitable pulses. An address buffer 125 connected to the 
40 internal registers 115, and a data buffer 130 connected 
to the internal data bus 105, are connected respectively 
to an external address bus and an external data bus 
(not shown in the drawings); the control unit 120 is con- 
nected directly to an external control bus (not shown in 
45 the drawings). An accumulator register (A) 135, for stor- 
ing an operand and the result of the various operations 
performed by the ALU 1 10. is connected to the internal 
data bus 105 and the ALU 1 10. A state register 140. the 
bits (flags) of which are used as indicators of particular 
5C operating conditions, is. connected to the ALU 110 and 
the control unit 120. An instruction register (IR) 145 is 
used to receive a current instruction to be executed, or 
at least a portion thereof comprising its operation code, 
from the internal data bus 105; this operation code is 
55 sent to an instruction decoder unit 148. as a function of 
the output from which the control unit 120 activates the 
various circuit elements to execute the current instruc- 
tion. 
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Some of the instructions utilised in the data 
processing device 100 include a constant value which 
must be input to the arithmetic-logic unit 1 1 0 in the form 
of an N bit operand field Cn.i...CiCo. In the method of 
the present invention, a group of constant values having 5 
a high statistical frequency of use is determined in 
advance. This determination is made, for example, from 
an analysis of the type of applications envisaged for the 
data processing device, or by utilising appropriate 
benchmark programs. The above-determined group of 10 
constant values is coded appropriately such that each 
constant is represented in the instructions by a coded 
operand field having fewer than N bits. 

The method of the present invention lends itself to 
being put into practice using various systems for coding is 
these constant values. In a first embodiment, constants 
having N bits are represented by a coded operand field 
of 2+log2N bits in the form aiaob|_.i.-.btbo. The bits bt- 
1 b-jbo (with L=log2N) comprise a position field and 
identify a bit position B (from 0 to N-1) in the operand 20 
field. The bits a^ao, which may take four different values 
(00, 01, 10 and 11), form a selector which defines the 
structure of the operand field. For example, the selector 
aiao indicates which bits of the operand field have the 
value 1, in particular: 25 

00: only the bit in position B; 
01 : all of the bits except for the bit in position B; 
10: all of the bits from the first position (0) to posi- 
tion B; 30 
11 : all of the bits froni position B+1 to the last posi- 
tion (N-1). 

In other words, the operand field is obtained from a 
string of N bits of value 0 by giving the bit in position B 35 
the value 1 when a-|=0. or by giving all of the bits from 
position 0 to position B the value 1 when 3^=1; when 
ao=0 the value thus obtained is left unchanged, while 
when ao=1 this value is bit-wise inverted. This coding 
system Is utilised advantageously for constants having 40 
a single bit of value 1 or 0, for constants of value 
0(00000000). ±1 (00000001, 11111110), ±2 
(00000010, 11111101), ±3 (00000011, 11111100). ±4 
(00000100, 11111011), ±8 (00001000, 11110111) and 
so on, used for loading, comparisons, rapid additions 45 
and subtractions (the constant -1 is also used as a mask 
in a toggle bit command to replace the one's comple- 
ment operation), and also for constants of the type 
11...100...0 and 00...0.1 1 ...1 used for sign or zero 
extension, and for the insertion or extraction of bit fields so 
in a word. 

In an alternative embodiment of the present inven- 
tion, constants having N bits are represented by an 
operand field coded as S+logaN bits in the form 
Soa-iaobL-i ...bibo. in which the bit Sq comprises a selec- ss 
tor bit which defines which bit of the operand field Is 
considered as the last bit in the decoding process 
described above. When So=0, position N-1 is consid- 



ered to be the last position of the operand field while 
when So=1, position N/2-1 Is considered to be the last 
position of the operand field; in the latter case, the bit 
position B ( from 0 to N/2-1 )is represented In the coded 
operand field only by the bits bL.2...b-|bo, while the bit bL. 
1 represents the value to be attributed to the bits of the 
operand field in the position N/2 to the position N-1. 
Several examples of constants having 16 bits coded 
according to the coding system described above with 
3+log2l 6=3-1-4=7 bits are given below: 



So 


a^ao 


b3b2bibo 


operand field 


0 


1 1 


0 111 


1111111100000000 


0 


0 0 


000 1 


0000000000000010 


1 


1 1 


0 10 1 


0000000011000000 


1 


1 0 


10 10 


1111111100000111 



This coding system allows constants having two 
non-contiguous blocks of bits of value 1 (or 0) to be rep- 
resented. This is particularly advantageous in reduced 
instruction set computers, or RISC, which are only able 
to operate on the full range of their registers; in this 
case, the system described above enables operations 
to be performed on data which Is shorter than a register. 

Returning to the drawing, the data processing 
device 100 includes an expansion unit 150 which 
receives a coded operand field from the instruction reg- 
ister 145 as input, and produces the corresponding 
operand field as output. The output of the expansion 
unit 150 is connected to a first Input of a multiplexer cir- 
cuit 155, the second Input of which Is connected to the 
Internal data bus 1 05. The multiplexer 1 55 transfers one 
of its two Inputs to Its output connected to the ALU 1 1 0 
In dependence on an appropriate control signal applied 
to a selector Input. In particular, a portion (address field) 
of the operation code of every instruction contains an 
Indication of the kind of address utilised thereby (for 
example. Immediate, direct. Indirect, relative, from the 
register, Indexed and the like). In the case of immediate 
addressing, an appropriate bit of this field enables 
immediate addressing without coding to be distin- 
guished from coded immediate addressing. In the case 
of immediate addressing without coding, the control unit 
120 sends a signal for reading the immediate operand 
from the bus 105 and therefore causes the multiplexer 
1 55 to transfer the data on the bus 1 05 to the ALU 110. 
In the case of coded immediate addressing, the control 
unit 120 enables the expansion unit 150 and, at the 
same time, commands the multiplexer 155 to transfer 
the output thereof to the ALU 110. This data processing 
device therefore enables the use of shorter instructions 
which require fewer memory access steps (machine 
cycles) to fetch them; this reduces the memory space 
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occupied by the programs and increases their speed of 
execution. 

With reference now to Figure 2, an embodiment of 
the expansion unit 150 is illustrated which may be used 
in combination with a coding system in the form a-iaobL- s 
i...bibo described above. The expansion unit 150 
receives the coded operand field aiaobL.i...b-|bo as 
input, and produces the corresponding operand field Cfg. 
i-.c^Cq as output. The expansion unit 150 includes a 
decoder 202 having L input terminals (for receiving the io 
position field bL.i...bibo as input) and N output termi- 
nals Un.i...UiUo in which, for every input combination, 
there corresponds a single output Ub of value 1 associ- 
ated with the position B identified by the position field bi_ 
-|...bibo. A corresponding combinatorial network 205- i5 
225 is associated with each of the outputs u^.^ ...uiUq of 
the decoder 202, The structure of these combinatorial 
networks is illustrated in detail with reference to the 
block 215 (similar considerations apply to the other 
combinatorial networks). The combinatorial network 20 
215 includes an input terminal connected to a corre- 
sponding output terminal U2 of the decoder 202. and an 
output terminal 235 which provides a corresponding bit 
C2 of the operand field. The combinatorial network 215 
includes three further input terminals 240-250 con- 25 
nected to three corresponding output terminals of the 
preceding combinatorial network 218. and three further 
output terminals 255-265 connected to three corre- 
sponding input terminals of the following combinatorial 
network 210; the output terminals of the last combinato- 30 
rial network 205 are not used, while the input terminals 
of the first combinatorial network 225 receive, respec- 
tively, the value a-i , the fixed value 0 (typically connect- 
ing this input terminal to a reference, or earth, terminal), 
and the value Bq- The terminals 240 and 250 are con- 35 
nected directly to the terminals 255 and 265 respec- 
tively. The terminals 240 and 245 are connected to the 
input terminals of an AND gate 270; the terminal 230 
and the output terminal of the AND gate 270 are con- 
nected to the input terminals of an OR gate 275. The 40 
output terminal of the OR gate is connected to the ter- 
minal 260; the terminal 250 and the same output termi- 
nal of the OR gate 275 are connected to the input 
terminals of an XOR gate 280. The output terminal of 
the XOR gate 280 is connected to the terminal 235. 45 

In order to describe the operation of the expansion 
unit 150, the position field bL-i-.-bibo is assumed to 
have the value 2. so that all of the outputs ujsj.-|."U-(Uo of 
the decoder 202 take the value 0 apart from the output 
U2=1 . If the bit ai has the value 0, all of the AND gates 50 
270 will have an input of value 0, and their outputs will 
therefore always be 0. The outputs of the OR gates 275 
will therefore be equal to the input values u^.i ...UiUo, 
that is. all having the value 0 with the exception of that 
corresponding to the output U2. which has the value 1 . If 55 
the bit a-, has the value 1 . the AND gate of the first com- 
binatorial network 225, having an input of value 0, will 
have an output of value 0; the output of the OR gate of 



the same combinatorial network 225 (connected to the 
input of the AND gate of the second combinatorial net- 
work 220) will therefore be equal to the input value Un.i . 
that is, 0. Continuing analogously, it is understood that 
the AND gates 270 up to the one corresponding to the 
output U2 (inclusive) have an input of value 0. so that its 
output will always be 0; the output of the corresponding 
OR gates 275 will therefore be equal to the input value 
U[4.^Ui^.2—^2' is, 0 for the inputs un.-|Un2-..U3. and 1 . 
for the input U2. Instead, both of the Inputs of the AND 
gates following that corresponding to the output U2 have 
a value 1, so that their output will always be equal to 1 ; 
the output of the corresponding OR gates will therefore 
always be equal to i . Considering now the bit Bq, it may 
be observed that when the bit has a value of 0, the 
output of the XOR gates 280 (which represents a corre- 
sponding bit of the operand field Cn.-|. .CiCq) is equal to 
that of the corresponding OR gates 275; when the bit ao 
has a value of 1 . the output of the XOR gates 280 is, 
instead, the opposite of that of the corresponding OR 
gates 275. 

Claims 

1 . A method for reducing the number of bits necessary 
to represent constant values for use in a data 
processing device (100) able to execute instruc- 
tions including an operand field which represents a 
constant value, the method comprising the steps of: 

defining a group of constant values by selecting 
them as a function of their statistical frequency 
of use; 

representing each constant value of the said 
group in the instructions by a coded operand 
field having fewer bits than the operand field; 
at least partially loading a current instruction 
into an instructions register (145) from a bus 
(105); 

if the current instruction contains a coded oper- 
and field, deriving a corresponding operand 
field from the coded operand field of the current 
instruction using expansion means (150); and 
selectively connecting the bus (105) and an 
output of the expansion means (150) as input 
to an arithmetic-logic unit (110). 

2. A method according to Claim 1 , in which the selec- 
tive connection step is executed as a function of the 
value of an address field of the current instruction. 

3. A method according to Claim 1 or 2. in which the 
operand field is constituted by N bits, and the coded 
operand field is constituted by a position field of 
L=log2Nbits indicative of a bit position B in the 
operand field, and by a 2-bit selector field, the step 
of deriving the operand field from the coded oper- 
and field comprising the steps of setting the bit in 
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position B of the operand field to the value 1 in cor- 
respondence with a first value of the selector field, 
all the bits with the exception of the bit in position B 
to the value 1 in correspondence with a second 
value of the selector field, all the bits from a first 5 
position to the position 8-1 to the value 1 in corre- 
spondence with a third value of the selector field, or 
all of the bits from the position B+l to a final posi- 
tion to the value 1 in correspondence with a fourth 
value of the selector field. 10 

4. A method according to Claim 3, in which the coded 
operand field further includes a mode selector bit, 
the last position being set to the value N-1 in corre- 
spondence with a first value of the mode selector is 
bit, the last position being set to the value N/2-1 in 
correspondence with a second value of the mode 
selector bit, the bits of the position field less one bit 
representing the position of bit B, the said one bit 
representing the value of the bits of the operand 20 
field from the position N\2 to the position N-1 in cor- 
respondence with the second value of the mode 
selector bit. 

5. A data processing device (100) able to execute 25 
instructions including an operand field which repre- 
sents a constant value, each constant value of a 
group of constant values chosen as a function of 
their statistical frequency of use being represented 

in the instructions by a coded operand field with 30 
fewer bits than the operand field, the data process- 
ing device (100) Including: 

an instruction register (145) for at least partially 
loading a current instruction from a bus (105): 35 
expansion means (150) for deriving a corre- 
sponding operand field from the coded oper- 
and field of the current instruction; 
a multiplexer (155) for selectively connecting 
the bus (105) and an output of the expansion 40 
means (150) as input to an arithmetic-logic unit 
(110). 

6. A data processing device (100) according to Claim 

5. in which the operand field is constituted by N bits 45 
and the coded operand field is constituted by a 
position field of LsloggN bits and a selector field 
having 2 bits, the expansion means (150) compris- 
ing a decoder (202) having L input terminals for 
receiving the position field as input and N output so 
terminals, and N combinatorial networks (205-225) 
each having first (240). second (245) and third 
(250) input terminals, and first (255). second (260) 
and third (265) output terminals connected, respec- 
tively, to corresponding output terminals of a pre- 55 
ceding combinatorial network (218) and 
corresponding input terminals of a following combi- 
natorial network (210). the first, second and third 



input terminals of a first combinatorial network 
(225) receiving as input, respectively, a first bit of 
the selector field, a value 0 and a second bit of the 
selector field, a fourth input terminal (230) con- 
nected to a corresponding output terminal of the 
decoder (202). and a fourth output terminal (235) 
for producing a corresponding bit of the operand 
field as output, the first (240) and third (250) input 
terminals being connected, respectively, to the first 
(255) and third (265) output terminals, the first (240) 
and second (245) input terminals being connected 
as inputs to an AND gate (270), the fourth input ter- 
minal (230) and an output terminal of the AND gate 
(270) being connected as input to an OR gate 
(275), an output terminal of the OR gate being con- 
nected to the second output terminal (260), the out- 
put terminal of the OR gate (275) and the third input 
terminal (250) being connected as input to an XOR 
gate (280), an output terminal of the XOR gate 
(280) being connected to the fourth output terminal 
(235). 

7. Adata processing device(IOO) according to Claim 5^ 
or 6, in which the data processing device (100) is a 
microprocessor. 
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